﻿//==================================================================
// Copyright (C) 2011 深圳市中旭企业管理股份有限公司
// 文件名: V_CrmPrivateCustom.cs
// 作 者：代码自动生成
// 日 期：2012-2-7 10:53:37
// 描 述：
// 版 本：1.00
// 修改历史纪录
// 版 本  修改时间      修改人            修改内容
// 1.00             
//==================================================================
using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;

namespace ZX.CRM.Library
{
    /// <summary>
    /// 
    /// </summary>
    [Serializable]
    [Table(Name = "V_CrmPrivateCustom")]
    [ZX.DBModule.Table("V_CrmPrivateCustom", "ID")]
    public class V_CrmPrivateCustom : ZX.DBModule.BaseEntity
    {
        #region Business Methods 业务方法
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> IDProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<Guid>("ID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid ID
        {
            get { return GetProperty(IDProperty); }
            set { SetProperty(IDProperty, value); }
        }

        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> CustomIdProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<Guid>("CustomId"));
        [Column]
        public Guid CustomId
        {
            get { return GetProperty(CustomIdProperty); }
            set { SetProperty(CustomIdProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> CustomUserProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<Guid>("CustomUser"));
        [Column]
        public Guid CustomUser
        {
            get { return GetProperty(CustomUserProperty); }
            set { SetProperty(CustomUserProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> ExplainProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Explain"));
        [Column]
        public string Explain
        {
            get { return GetProperty(ExplainProperty); }
            set { SetProperty(ExplainProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> AddUserProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<Guid>("AddUser"));
        [Column]
        public Guid AddUser
        {
            get { return GetProperty(AddUserProperty); }
            set { SetProperty(AddUserProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<DateTime> AddTimeProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<DateTime>("AddTime"));
        [Column]
        public DateTime AddTime
        {
            get { return GetProperty(AddTimeProperty); }
            set { SetProperty(AddTimeProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> CustomerUserProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("CustomerUser"));
        [Column]
        public string CustomerUser
        {
            get { return GetProperty(CustomerUserProperty); }
            set { SetProperty(CustomerUserProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> AddUserNameProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("AddUserName"));
        [Column]
        public string AddUserName
        {
            get { return GetProperty(AddUserNameProperty); }
            set { SetProperty(AddUserNameProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> CustomerNameProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("CustomerName"));
        [Column]
        public string CustomerName
        {
            get { return GetProperty(CustomerNameProperty); }
            set { SetProperty(CustomerNameProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> CodeProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Code"));
        [Column]
        public string Code
        {
            get { return GetProperty(CodeProperty); }
            set { SetProperty(CodeProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> AreaIdProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<Guid>("AreaId"));
        [Column]
        public Guid AreaId
        {
            get { return GetProperty(AreaIdProperty); }
            set { SetProperty(AreaIdProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> DecisionmakerProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Decisionmaker"));
        [Column]
        public string Decisionmaker
        {
            get { return GetProperty(DecisionmakerProperty); }
            set { SetProperty(DecisionmakerProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> DecisionTelProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("DecisionTel"));
        [Column]
        public string DecisionTel
        {
            get { return GetProperty(DecisionTelProperty); }
            set { SetProperty(DecisionTelProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> DecisionPositionProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("DecisionPosition"));
        [Column]
        public string DecisionPosition
        {
            get { return GetProperty(DecisionPositionProperty); }
            set { SetProperty(DecisionPositionProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> StateProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("State"));
        [Column]
        public string State
        {
            get { return GetProperty(StateProperty); }
            set { SetProperty(StateProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> ProvinceProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Province"));
        [Column]
        public string Province
        {
            get { return GetProperty(ProvinceProperty); }
            set { SetProperty(ProvinceProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> CityProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("City"));
        [Column]
        public string City
        {
            get { return GetProperty(CityProperty); }
            set { SetProperty(CityProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> AreaProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Area"));
        [Column]
        public string Area
        {
            get { return GetProperty(AreaProperty); }
            set { SetProperty(AreaProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> AddressProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Address"));
        [Column]
        public string Address
        {
            get { return GetProperty(AddressProperty); }
            set { SetProperty(AddressProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> ProductProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Product"));
        [Column]
        public string Product
        {
            get { return GetProperty(ProductProperty); }
            set { SetProperty(ProductProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> TradeProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Trade"));
        [Column]
        public string Trade
        {
            get { return GetProperty(TradeProperty); }
            set { SetProperty(TradeProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> DeptNameProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("DeptName"));
        [Column]
        public string DeptName
        {
            get { return GetProperty(DeptNameProperty); }
            set { SetProperty(DeptNameProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> PersonProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("Person"));
        [Column]
        public string Person
        {
            get { return GetProperty(PersonProperty); }
            set { SetProperty(PersonProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> SaleadviserIdProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<Guid>("SaleadviserId"));
        [Column]
        public Guid SaleadviserId
        {
            get { return GetProperty(SaleadviserIdProperty); }
            set { SetProperty(SaleadviserIdProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<Guid> Expr1Property = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<Guid>("Expr1"));
        [Column]
        public Guid Expr1
        {
            get { return GetProperty(Expr1Property); }
            set { SetProperty(Expr1Property, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> UNameProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("UName"));
        [Column]
        public string UName
        {
            get { return GetProperty(UNameProperty); }
            set { SetProperty(UNameProperty, value); }
        }
        /// <summary>
        /// 
        /// </summary>
        private static PropertyInfo<string> CustomerAddUserProperty = RegisterProperty(typeof(V_CrmPrivateCustom), new PropertyInfo<string>("CustomerAddUser"));
        [Column]
        public string CustomerAddUser
        {
            get { return GetProperty(CustomerAddUserProperty); }
            set { SetProperty(CustomerAddUserProperty, value); }
        }
        #endregion

        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "Explain");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Explain", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "CustomerUser");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("CustomerUser", 30));
            ValidationRules.AddRule(CommonRules.StringRequired, "AddUserName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("AddUserName", 30));
            ValidationRules.AddRule(CommonRules.StringRequired, "CustomerName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("CustomerName", 50));
            ValidationRules.AddRule(CommonRules.StringRequired, "Code");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Code", 15));
            ValidationRules.AddRule(CommonRules.StringRequired, "Decisionmaker");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Decisionmaker", 30));
            ValidationRules.AddRule(CommonRules.StringRequired, "DecisionTel");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("DecisionTel", 20));
            ValidationRules.AddRule(CommonRules.StringRequired, "DecisionPosition");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("DecisionPosition", 20));
            ValidationRules.AddRule(CommonRules.StringRequired, "State");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("State", 30));
            ValidationRules.AddRule(CommonRules.StringRequired, "Province");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Province", 20));
            ValidationRules.AddRule(CommonRules.StringRequired, "City");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("City", 20));
            ValidationRules.AddRule(CommonRules.StringRequired, "Area");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Area", 20));
            ValidationRules.AddRule(CommonRules.StringRequired, "Address");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Address", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "Product");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Product", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "Trade");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Trade", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "DeptName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("DeptName", 50));
            ValidationRules.AddRule(CommonRules.StringRequired, "Person");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Person", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "UName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("UName", 30));
            ValidationRules.AddRule(CommonRules.StringRequired, "CustomerAddUser");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("CustomerAddUser", 30));
            //base.AddBusinessRules();
        }
        #endregion

        #region Factory Methods 工厂方法

        public V_CrmPrivateCustom() { }

        public static V_CrmPrivateCustom New()
        {
            return DataPortal.Create<V_CrmPrivateCustom>();
        }
        public static V_CrmPrivateCustom Get(Guid ID)
        {
            return DataPortal.Fetch<V_CrmPrivateCustom>(new SingleLazyCriteria<V_CrmPrivateCustom, Guid>(ID, false));
        }
        public static void Delete(Guid ID)
        {
            DataPortal.Delete(ID);
        }

        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid ID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("ID").Equal(ID);

                var data = db.Select<V_CrmPrivateCustom>(q)[0];
                LoadProperty(IDProperty, data.ID);
                LoadProperty(CustomIdProperty, data.CustomId);
                LoadProperty(CustomUserProperty, data.CustomUser);
                LoadProperty(ExplainProperty, data.Explain);
                LoadProperty(AddUserProperty, data.AddUser);
                LoadProperty(AddTimeProperty, data.AddTime);
                LoadProperty(CustomerUserProperty, data.CustomerUser);
                LoadProperty(AddUserNameProperty, data.AddUserName);
                LoadProperty(CustomerNameProperty, data.CustomerName);
                LoadProperty(CodeProperty, data.Code);
                LoadProperty(AreaIdProperty, data.AreaId);
                LoadProperty(DecisionmakerProperty, data.Decisionmaker);
                LoadProperty(DecisionTelProperty, data.DecisionTel);
                LoadProperty(DecisionPositionProperty, data.DecisionPosition);
                LoadProperty(StateProperty, data.State);
                LoadProperty(ProvinceProperty, data.Province);
                LoadProperty(CityProperty, data.City);
                LoadProperty(AreaProperty, data.Area);
                LoadProperty(AddressProperty, data.Address);
                LoadProperty(ProductProperty, data.Product);
                LoadProperty(TradeProperty, data.Trade);
                LoadProperty(DeptNameProperty, data.DeptName);
                LoadProperty(PersonProperty, data.Person);
                LoadProperty(SaleadviserIdProperty, data.SaleadviserId);
                LoadProperty(Expr1Property, data.Expr1);
                LoadProperty(UNameProperty, data.UName);
                LoadProperty(CustomerAddUserProperty, data.CustomerAddUser);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(IDProperty);
        }
        #endregion
    }
}

